草庐IT

c++ - std::byte 的用例

全部标签

c++ - 使用 mpirun/mpiexec 运行时检测不使用 MPI

我正在编写一个程序(在C++11中),可以选择使用MPI并行运行。该项目使用CMake进行配置,如果找不到MPI,CMake会自动禁用MPI并显示相关警告消息。但是,我担心一个非常合理的用例,即用户在HPC集群上配置和编译程序,忘记加载MPI模块,并且没有注意到警告。然后同一用户可能会尝试运行该程序,注意未找到mpirun,包括MPI模块,但忘记重新编译。如果用户随后使用mpirun运行该程序,这将起作用,但该程序将只运行多次而没有任何并行化,因为MPI在编译时被禁用。为了防止用户认为程序是并行运行的,我想让程序在这种情况下显示一条错误消息。我的问题是:如何在不使用MPI库函数的情况下

c++ - 为什么 std::shared_ptr 提供 operator<<?

std::shared_ptr提供operator它只是写出它的地址。没有operator>>只记录地址,不记录内容。我想知道它在哪些情况下有用。 最佳答案 因为是一个潜在有用的东西在原始指针上执行。这是安全的,原始指针就是这样做的,shared_ptr在某些情况下应该用于替换原始指针。相比之下,>>很少有意义。与原始指针不同,将指针值存储在共享指针中会取得它的所有权。我可以some_stream>>raw_ptr除非我用ptr做些什么没有任何问题;有点奇怪,但没有立即中断。对shared_ptr做同样的事情只有在极其深奥的情况下才

c++ - 如何使用 msgfmt 验证格式字符串中的位置符号占位符?

在翻译文本中使用类似printf的格式字符串时,msgfmt--check检查翻译是否仍然包含占位符。例如,在以下代码上运行xgettextprintf(gettext("string:%s,int:%d"),str,i)生成一个.po文件,其中msgid标记为c-format并且其值为"string:%s,整数:%d"。如果翻译者在翻译中忘记了%s或%d,则msgfmt会提示:numberofformatspecificationsin'msgid'and'msgstr'doesnotmatch不幸的是,此检查不适用于使用位置符号的格式字符串,例如boost::format(gett

c++ - 不完整类型的 std::unique_ptr 无法编译

我将pimpl-idiom与std::unique_ptr结合使用:classwindow{window(constrectangle&rect);private:classwindow_impl;//definedelsewherestd::unique_ptrimpl_;//won'tcompile};但是,我在的第304行收到关于使用不完整类型的编译错误:Invalidapplicationof'sizeof'toanincompletetype'uixx::window::window_impl'据我所知,std::unique_ptr应该能够与不完整的类型一起使用。这是lib

c++ - 为什么 malloc 不返回?

我有一个正在运行的线程(OSX10.10.5)与此堆栈跟踪一起挂起。它是在运行约20小时后出现的,可能与内存不足有关。但是,问题是,为什么malloc不直接返回null?为什么线程的执行需要停止?实际请求的字节数很少(对于路径上的字符串操作)。std::wstringfinalPath=itsPath.substr(0,ls+1);1operatornew(unsignedlong)+37(libc++abi.dylib+124485)[0xa0339645]21malloc+29(libsystem_malloc.dylib+3997)[0xa1829f9d]21malloc_zon

c++ - 用于 cv::Mat 参数的 OpenCV std::vector

执行这个:std::vectorpts;//contains4elementscv::MatptsMat=((cv::InputArray)pts).getMat();在一台机器上,我得到一个带有2个channel的4-by-1cv::Mat。每个元素代表一个二维点。在另一台机器上,我得到一个2090-by-1cv::Mat,它有2个channel,数据很奇怪。这是错误的,这是一个问题,因为vector只包含4个项目。在两台机器上都使用OpenCV3.1从源代码构建,在Windows10上使用CMake。编辑我开始在另一台机器上遇到类似的问题。在Debug模式下的VisualStudi

c++ - 从 C 代码调用具有复杂参数和复杂返回类型的 C++ 函数

我有一个C++数学库并用Rust编写了一个项目。由于无法直接从Rust调用C++,但可以调用C,因此我决定编写一个从C++到C的标准包装器。除具有复杂参数的函数外,一切都或多或少地按预期工作,其中虚部由于某种原因丢失。下面我提供mwe。export_c++.h#ifdef__cplusplus#includestd::complexfoo(conststd::complexa);#endif#ifdef__cplusplusextern"C"{#endif#includedouble_Complexc_foo(constdouble_Complexa);#ifdef__cplusplu

c++ - 为什么可以将 std::bind 分配给参数不匹配的 std::function?

我有如下代码:#include#includeusingnamespacestd;voidF(intx){coutf1=std::bind(F,std::placeholders::_1);f1(100);//Thisworks,willprint100.intx=0;std::functionf2=std::bind(F,x);f2();//Thisworks,willprint0.std::functionf3=std::bind(F,x);f3(200);//BUTWHYTHISWORKS??????Itprints0.return0;}我的编译器信息是:AppleLLVM版本6

c++ - 使用 std::hexfloat 读写

这段代码在我的机器上打印了0,但我期望是0.3。怎么了?我在最新的ArchLinux上使用g++6.3.1。编译标志似乎无关紧要。#include#includeintmain(){std::stringstreams;s>std::hexfloat>>d)std::cout 最佳答案 使用doubled=std::strtod(s.str().c_str(),NULL);作为解决方法。这似乎是一个错误。 关于c++-使用std::hexfloat读写,我们在StackOverflow上

c++ - 错误 C2893 : Failed to specialize function template 'unknown-type std::invoke(_Callable &&,_Types &&...) noexcept(<expr>)'

下面是一个给出编译时错误的程序。这主要与D类中的Boo函数有关。我最终尝试使用多个线程来调用solve方法,但目前这对我来说似乎不太有效,无法做到这一点。错误是:1>d:\dummy\project1\trash.cpp(37):warningC4101:'d':unreferencedlocalvariable1>c:\programfiles(x86)\microsoftvisualstudio\2017\community1\vc\tools\msvc\14.11.25503\include\thr\xthread(240):errorC2672:'std::invoke':no